# MICROS 32 BITS STM - IC

ROBINSON JIMENEZ MORENO

LUISA FERNANDA GARCIA VARGAS









## 23.3.5 Input capture mode

In Input capture mode, the Capture/Compare Registers (TIMx\_CCRx) are used to latch the value of the counter after a transition detected by the corresponding ICx signal. When a capture occurs, the corresponding CCXIF flag (TIMx\_SR register) is set and an interrupt or a DMA request can be sent if they are enabled. If a capture occurs while the CCxIF flag was already high, then the over-capture flag CCxOF (TIMx\_SR register) is set. CCxIF can be cleared by software by writing it to 0 or by reading the captured data stored in the TIMx\_CCRx register. CCxOF is cleared when you write it to 0.

The following example shows how to capture the counter value in TIMx\_CCR1 when TI1 input rises. To do this, use the following procedure:

- Select the active input: TIMx\_CCR1 must be linked to the TI1 input, so write the CC1S bits to 01 in the TIMx\_CCMR1 register. As soon as CC1S becomes different from 00, the channel is configured in input and the TIMx\_CCR1 register becomes read-only.
- 2. Program the input filter duration you need with respect to the signal you connect to the timer (when the input is one of the TIx (ICxF bits in the TIMx\_CCMRx register). Let's imagine that, when toggling, the input signal is not stable during at must 5 internal clock cycles. We must program a filter duration longer than these 5 clock cycles. We can validate a transition on TI1 when 8 consecutive samples with the new level have been

## 22.4.5 TIM1/TIM8 status register (TIMx\_SR)

Address offset: 0x10

Reset value: 0x0000 0000

| 31         | 30         | 29   | 28          | 27          | 26   | 25         | 24        | 23       | 22       | 21         | 20         | 19         | 18         | 17         | 16       |
|------------|------------|------|-------------|-------------|------|------------|-----------|----------|----------|------------|------------|------------|------------|------------|----------|
| Res.       | Res.       | Res. | Res.        | Res.        | Res. | Res.       | Res.      | Res.     | Res.     | Res.       | Res.       | Res.       | Res.       | CC6IF      | CC5IF    |
|            |            |      |             |             |      |            |           |          |          |            |            |            |            | rc_w0      | rc_w0    |
|            |            |      |             |             |      |            |           |          |          |            |            |            |            |            |          |
| 15         | 14         | 13   | 12          | 11          | 10   | 9          | 8         | 7        | 6        | 5          | 4          | 3          | 2          | 1          | 0        |
| 15<br>Res. | 14<br>Res. | 13   | 12<br>CC40F | 11<br>CC3OF |      | 9<br>CC1OF | 8<br>B2IF | 7<br>BIF | 6<br>TIF | 5<br>COMIF | 4<br>CC4IF | 3<br>CC3IF | 2<br>CC2IF | 1<br>CC1IF | 0<br>UIF |









- 3. Select the edge of the active transition on the TI1 channel by writing the CC1P and CC1NP and CC1NP bits to 000 in the TIMx\_CCER register (rising edge in this case).
- Program the input prescaler. In our example, we wish the capture to be performed at each valid transition, so the prescaler is disabled (write IC1PS bits to 00 in the TIMx\_CCMR1 register).
- Enable capture from the counter into the capture register by setting the CC1E bit in the TIMx\_CCER register.
- If needed, enable the related interrupt request by setting the CC1IE bit in the TIMx\_DIER register, and/or the DMA request by setting the CC1DE bit in the TIMx\_DIER register.

## When an input capture occurs:

- The TIMx\_CCR1 register gets the value of the counter on the active transition.
- CC1IF flag is set (interrupt flag). CC1OF is also set if at least two consecutive captures
  occurred whereas the flag was not cleared.
- An interrupt is generated depending on the CC1IE bit.





#### Bits 7:4 IC1F[3:0]: Input capture 1 filter

This bit-field defines the frequency used to sample TI1 input and the length of the digital filter applied to TI1. The digital filter is made of an event counter in which N consecutive events are needed to validate a transition on the output:

0000: No filter, sampling is done at fDTS

0001: f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=2

0010: f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=4

0011: f<sub>SAMPLING</sub>=f<sub>CK\_INT</sub>, N=8

0100: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=6

0101: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=8

0110: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=6

0111: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=8

1000: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=6

1001: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=8

1010: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=5

1011: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=6

1100: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=8

1101: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=5

1110: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=6

1111: f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=8

## Bits 3:2 IC1PSC: Input capture 1 prescaler

This bit-field defines the ratio of the prescaler acting on CC1 input (IC1). The prescaler is reset as soon as CC1E='0' (TIMx\_CCER register).

00: no prescaler, capture is done each time an edge is detected on the capture input

01: capture is done once every 2 events

10: capture is done once every 4 events

11: capture is done once every 8 events





## TIM2->CR1=1;



# 23.4.1 TIMx control register 1 (TIMx\_CR1)

Address offset: 0x00

Reset value: 0x0000

| 15   | 14   | 13   | 12   | 11           | 10   | 9   | 8     | 7    | 6  | 5  | 4   | 3   | 2   | 1    | 0   |
|------|------|------|------|--------------|------|-----|-------|------|----|----|-----|-----|-----|------|-----|
| Res. | Res. | Res. | Res. | UIFRE<br>MAP | Res. | CKD | [1:0] | ARPE | CI | MS | DIR | OPM | URS | UDIS | CEN |
|      |      |      |      | rw           |      | rw  | rw    | rw   | rw | rw | rw  | rw  | rw  | rw   | rw  |
|      |      |      |      |              |      |     |       |      |    |    |     |     |     |      |     |

Bit 0 CEN: Counter enable

0: Counter disabled
1: Counter enabled

Note: External clock, gated mode and encoder mode can work only if the CEN bit has been previously set by software. However trigger mode can set the CEN bit automatically by hardware.

CEN is cleared automatically in one-pulse mode, when an update event occurs.







# 23.4.2 TIMx control register 2 (TIMx\_CR2)

Address offset: 0x04

Reset value: 0x0000

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6  | 5        | 4  | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|------|----|----------|----|------|------|------|------|
| Res. | TI1S |    | MMS[2:0] |    | CCDS | Res. | Res. | Res. |
|      |      |      |      |      |      |      |      | rw   | rw | rw       | rw | rw   |      |      |      |
|      |      |      |      |      |      |      | BIN  | 1    | 0  | 0        | 0  | 0    | 0    | 0    | 0    |
|      |      |      |      |      |      |      | OX   |      |    | 8        |    |      |      | 0    |      |

Bit 7 TI1S: TI1 selection

0: The TIMx\_CH1 pin is connected to TI1 input

1: The TIMx\_CH1, CH2 and CH3 pins are connected to the TI1 input (XOR combination) See also Section 22.3.24: Interfacing with Hall sensors on page 696





# 23.4.7

# TIMx capture/compare mode register 1 (TIMx\_CCMR1)/CCMR2

Address offset: 0x18

Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by configuring the corresponding CCxS bits. All the other bits of this register have a different function in input and in output mode. For a given bit,

OCxx describes its function when the channel is configured in output. ICxx describes its

tunction when the channel is configured in input. So you must take care that the same bit can have a different meaning for the input stage and for the output stage.

| 31    | 30   | 29       | 28   | 27    | 26     | 25   | 24          | 23    | 22   | 21       | 20   | 19    | 18     | 17   | 16          |
|-------|------|----------|------|-------|--------|------|-------------|-------|------|----------|------|-------|--------|------|-------------|
| Res.  | Res. | Res.     | Res. | Res.  | Res.   | Res. | OC2M<br>[3] | Res.  | Res. | Res.     | Res. | Res.  | Res.   | Res. | OC1M<br>[3] |
|       |      |          |      |       |        |      | Res.        |       |      |          |      |       |        |      | Res.        |
|       |      |          |      |       |        |      | rw          |       |      |          |      |       |        |      | rw          |
| 15    | 14   | 13       | 12   | 11    | 10     | 9    | 8           | 7     | 6    | 5        | 4    | 3     | 2      | 1    | 0           |
| OC2CE | (    | OC2M[2:0 | )]   | OC2PE | OC2FE  | 000  | 014-01      | OC1CE | (    | OC1M[2:0 | ]    | OC1PE | OC1FE  | 0019 | 014.01      |
|       | IC2F | [3:0]    |      | IC2PS | C[1:0] | 002  | S[1:0]      |       | IC1F | [3:0]    |      | IC1PS | C[1:0] | COR  | S[1:0]      |
| rw    | rw   | rw       | rw   | rw    | rw     | rw   | rw          | rw    | rw   | rw       | rw   | rw    | rw     | rw   | rw          |







Bits 1:0 CC1S: Capture/Compare 1 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC1 channel is configured as output.

01: CC1 channel is configured as input, IC1 is mapped on TI1.

10: CC1 channel is configured as input, IC1 is mapped on TI2.

11: CC1 channel is configured as input, IC1 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC1S bits are writable only when the channel is OFF (CC1E = 0 in  $TIMx\_CCER$ ).







# 22.4.8 TIM1/TIM8 capture/compare mode register 2 (TIMx\_CCMR2)

Address offset: 0x1C

Reset value: 0x0000 0000

Refer to the above CCMR1 register description.

| 31        | 30   | 29       | 28   | 27        | 26        | 25   | 24      | 23         | 22   | 21       | 20   | 19        | 18        | 17   | 16      |
|-----------|------|----------|------|-----------|-----------|------|---------|------------|------|----------|------|-----------|-----------|------|---------|
| Res.      | Res. | Res.     | Res. | Res.      | Res.      | Res. | OC4M[3] | Res.       | Res. | Res.     | Res. | Res.      | Res.      | Res. | OC3M[3] |
| Res.      | Res. | Res.     | Res. | Res.      | Res.      | Res. | Res.    | Res.       | Res. | Res.     | Res. | Res.      | Res.      | Res. | Res.    |
|           |      |          |      |           |           |      | rw      |            |      |          |      |           |           |      | rw      |
| 15        | 14   | 13       | 12   | 11        | 10        | 9    | 8       | 7          | 6    | 5        | 4    | 3         | 2         | 1    | 0       |
| OC4<br>CE | (    | DC4M[2:0 | )]   | OC4<br>PE | OC4<br>FE | CC4  | IS[1:0] | OC3<br>CE. | (    | OC3M[2:0 | )]   | OC3<br>PE | OC3<br>FE | CC3  | S[1:0]  |
|           | IC4F | [3:0]    |      | IC4PS     | C[1:0]    |      | . ]     |            | IC3F | [3:0]    |      | IC3P9     | SC[1:0]   |      |         |
| rw        | rw   | rw       | rw   | rw        | rw        | rw   | rw      | rw         | rw   | rw       | rw   | rw        | rw        | rw   | rw      |



#### Bits 9:8 CC2S: Capture/Compare 2 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC2 channel is configured as output

01: CC2 channel is configured as input, IC2 is mapped on TI2

10: CC2 channel is configured as input, IC2 is mapped on TI1

11: CC2 channel is configured as input, IC2 is mapped on TRC. This mode is working only if an

internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC2S bits are writable only when the channel is OFF (CC2E = '0' in TIMx\_CCER).

#### Bits 1:0 CC3S: Capture/Compare 3 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC3 channel is configured as output

01: CC3 channel is configured as input, IC3 is mapped on TI3

10: CC3 channel is configured as input, IC3 is mapped on TI4

11: CC3 channel is configured as input, IC3 is mapped on TRC. This mode is working only if

an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC3S bits are writable only when the channel is OFF (CC3E = '0' in TIMx\_CCER).

#### Bits 9:8 CC4S: Capture/Compare 4 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC4 channel is configured as output

01: CC4 channel is configured as input, IC4 is mapped on TI4

10: CC4 channel is configured as input, IC4 is mapped on TI3

11: CC4 channel is configured as input, IC4 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC4S bits are writable only when the channel is OFF (CC4E = '0' in TIMx CCER).





# 23.4.9 TIMx capture/compare enable register (TIMx\_CCER)

Address offset: 0x20

Reset value: 0x0000

| 15    | 14   | 13   | 12   | 11    | 10   | 9    | 8    | 7     | 6    | 5    | 4    | 3     | 2    | 1    | 0    |
|-------|------|------|------|-------|------|------|------|-------|------|------|------|-------|------|------|------|
| CC4NP | Res. | CC4P | CC4E | CC3NP | Res. | CC3P | CC3E | CC2NP | Res. | CC2P | CC2E | CC1NP | Res. | CC1P | CC1E |
| rw    |      | rw   | rw   |

Bit 0 CC1E: Capture/Compare 1 output enable.

CC1 channel configured as output:

0: Off - OC1 is not active

1: On - OC1 signal is output on the corresponding output pin

**CC1 channel configured as input**: This bit determines if a capture of the counter value can actually be done into the input capture/compare register 1 (TIMx\_CCR1) or not.

0: Capture disabled

1: Capture enabled







Bit 1 CC1P: Capture/Compare 1 output Polarity.

CC1 channel configured as output:

0: OC1 active high 1: OC1 active low

**CC1 channel configured as input**: CC1NP/CC1P bits select TI1FP1 and TI2FP1 polarity for trigger or capture operations.

00: noninverted/rising edge

Circuit is sensitive to TIxFP1 rising edge (capture, trigger in reset, external clock or trigger mode), TIxFP1 is not inverted (trigger in gated mode, encoder mode).

01: inverted/falling edge

Circuit is sensitive to TIxFP1 falling edge (capture, trigger in reset, external clock or trigger mode), TIxFP1 is inverted (trigger in gated mode, encoder mode).

10: reserved, do not use this configuration.

11: noninverted/both edges

Circuit is sensitive to both TIxFP1 rising and falling edges (capture, trigger in reset, external clock or trigger mode), TIxFP1 is not inverted (trigger in gated mode). This configuration must not be used for encoder mode.

Note:

The state of the external IO pins connected to the standard OCx channels depends on the OCx channel state and the GPIO and AFIO registers.







# 23.4.10 TIMx counter (TIMx\_CNT)

Address offset: 0x24

Reset value: 0x0000

| 31                      | 30        | 29 | 28 | 27 | 26 | 25 | 24       | 23        | 22         | 21   | 20 | 19 | 18 | 17 | 16 |
|-------------------------|-----------|----|----|----|----|----|----------|-----------|------------|------|----|----|----|----|----|
| CNT[31]<br>or<br>UIFCPY |           |    |    |    |    | CN | T[30:16] | (dependir | ng on time | ers) |    |    |    |    |    |
| rw or r                 | rw        | rw | rw | rw | rw | rw | rw       | rw        | rw         | rw   | rw | rw | rw | rw | rw |
| 15                      | 14        | 13 | 12 | 11 | 10 | 9  | 8        | 7         | 6          | 5    | 4  | 3  | 2  | 1  | 0  |
|                         | CNT[15:0] |    |    |    |    |    |          |           |            |      |    |    |    |    |    |
| rw                      | rw        | rw | rw | rw | rw | rw | rw       | rw        | rw         | rw   | rw | rw | rw | rw | rw |

Bits 30:16 CNT[30:16]: Most significant part counter value (on TIM2 and TIM5)

Bits 15:0 CNT[15:0]: Least significant part of counter value







Reset value: 0x0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | PSC[ | [15:0] |    |    |    |    |    |    |    |
| rw   | rw     | rw | rw | rw | rw | rw | rw | rw |

Bits 15:0 PSC[15:0]: Prescaler value

The counter clock frequency CK\_CNT is equal to f<sub>CK\_PSC</sub> / (PSC[15:0] + 1)
PSC contains the value to be loaded in the active prescaler register at each update event

(including when the counter is cleared through UG bit of TIMx\_EGR register or through trigger controller when configured in "reset mode").









## 23.4.4 TIMx DMA/Interrupt enable register (TIMx\_DIER)

Address offset: 0x0C

Reset value: 0x0000

| 15   | 14  | 13   | 12    | 11    | 10    | 9     | 8   | 7    | 6   | 5    | 4     | 3     | 2     | 4     | 0   |
|------|-----|------|-------|-------|-------|-------|-----|------|-----|------|-------|-------|-------|-------|-----|
| Res. | TDE | Res. | CC4DE | CC3DE | CC2DE | CC1DE | UDE | Res. | TIE | Res. | CC4IE | CC3IE | CC2IE | CC1IE | UIE |
|      | rw  |      | rw    | rw    | rw    | rw    | rw  |      | rw  |      | rw    | rw    | rw    | rw    | rw  |
|      |     |      |       |       |       |       |     |      |     |      |       |       |       |       |     |

Bit 4 CC4IE: Capture/Compare 4 interrupt enable

0: CC4 interrupt disabled.1: CC4 interrupt enabled.

Bit 3 CC3IE: Capture/Compare 3 interrupt enable

0: CC3 interrupt disabled.1: CC3 interrupt enabled.

Bit 2 CC2IE: Capture/Compare 2 interrupt enable

0: CC2 interrupt disabled.1: CC2 interrupt enabled.

Bit 1 CC1IE: Capture/Compare 1 interrupt enable

0: CC1 interrupt disabled.1: CC1 interrupt enabled.

Bit 0 UIE: Update interrupt enable

0: Update interrupt disabled.1: Update interrupt enabled.







TIM2->ARR=60000;

# 23.4.12 TIMx auto-reload register (TIMx\_ARR)

Address offset: 0x2C

Reset value: 0xFFFF FFFF

| 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24        | 23        | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|--------|-----------|-----------|---------|----|----|----|----|----|----|
|    |    |    |    |    |    | ARR[31 | :16] (dep | ending or | timers) |    |    |    |    |    |    |
| rw     | rw        | rw        | rw      | rw | rw | rw | rw | rw | rw |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8         | 7         | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |        | ARR       | [15:0]    |         |    |    |    |    |    |    |
| rw     | rw        | rw        | rw      | rw | rw | rw | rw | rw | rw |

Bits 31:16 ARR[31:16]: High auto-reload value (on TIM2 and TIM5)

Bits 15:0 ARR[15:0]: Low Auto-reload Prescaler value

ARR is the value to be loaded in the actual auto-reload register.

Refer to the Section 23.3.1: Time-base unit on page 706 for more details about ARR update and behavior.

The counter is blocked while the auto-reload value is null.







# 23.4.13 TIMx capture/compare register 1 (TIMx\_CCR1)

Address offset: 0x34

tiempo=TIM2->CCR1;

Reset value: 0x0000

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24         | 23         | 22         | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|-------|------------|------------|------------|------|------|------|------|------|------|
|      |      |      |      |      |      | CCR1[ | 31:16] (de | epending ( | on timers) | )    |      |      |      |      |      |
| rw/r  | rw/r       | rw/r       | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |
| 15   | 14   | 13   | 12   | 11   | 10   | 9     | 8          | 7          | 6          | 5    | 4    | 3    | 2    | 1    | 0    |
|      |      |      |      |      |      |       | CCF        | R1[15:0]   |            |      |      |      |      |      |      |
| rw/r  | rw/r       | rw/r       | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |

Bits 31:16 CCR1[31:16]: High Capture/Compare 1 value (on TIM2 and TIM5)

Bits 15:0 CCR1[15:0]: Low Capture/Compare 1 value

## If channel CC1 is configured as output:

CCR1 is the value to be loaded in the actual capture/compare 1 register (preload value). It is loaded permanently if the preload feature is not selected in the TIMx\_CCMR1 register (bit OC1PE). Else the preload value is copied in the active capture/compare 1 register when an update event occurs.

The active capture/compare register contains the value to be compared to the counter TIMx\_CNT and signaled on OC1 output.





## $RCC \rightarrow APB1ENR = 0x1;$

## 5.3.13 RCC APB1 peripheral clock enable register (RCC\_APB1ENR)

| 31          | 30          | 29        | 28        | 27         | 26         | 25           | 24          | 23          | 22          | 21         | 20          | 19          | 18               | 17               | 16            |
|-------------|-------------|-----------|-----------|------------|------------|--------------|-------------|-------------|-------------|------------|-------------|-------------|------------------|------------------|---------------|
| UART8<br>EN | UART7<br>EN | DAC<br>EN | PWR<br>EN | CEC<br>EN  | CAN2<br>EN | CAN1<br>EN   | I2C4<br>EN  | I2C3<br>EN  | I2C2<br>EN  | I2C1<br>EN | UART5<br>EN | UART4<br>EN | USART<br>3<br>EN | USART<br>2<br>EN | SPDIFRX<br>EN |
| 15          | 14          | 13        | 12        | 11         | 10         | 9            | 8           | 7           | 6           | 5          | 4           | 3           | 2                | 1                | -             |
| SPI3<br>EN  | SPI2<br>EN  | Res.      | Res.      | WWDG<br>EN | Res.       | LPTIM1<br>EN | TIM14<br>EN | TIM13<br>EN | TIM12<br>EN | TIM7<br>EN | TIM6<br>EN  | TIM5<br>EN  | TIM4<br>EN       | TIM3<br>EN       | TIM2<br>EN    |

Bit 5 TIM7EN: TIM7 clock enable

This bit is set and cleared by software.

0: TIM7 clock disabled

1: TIM7 clock enabled

Bit 4 TIM6EN: TIM6 clock enable

This bit is set and cleared by software.

0: TIM6 clock disabled

1: TIM6 clock enabled

Bit 3 TIM5EN: TIM5 clock enable

This bit is set and cleared by software.

0: TIM5 clock disabled

1: TIM5 clock enabled

Bit 2 **TIM4EN:** TIM4 clock enable

This bit is set and cleared by software.

0: TIM4 clock disabled

1: TIM4 clock enabled

Bit 1 TIM3EN: TIM3 clock enable

This bit is set and cleared by software.

0: TIM3 clock disabled

1: TIM3 clock enabled

Bit 0 TIM2EN: TIM2 clock enable

This bit is set and cleared by software.

0: TIM2 clock disabled

1: TIM2 clock enabled





# 5.3.14 RCC APB2 peripheral clock enable register (RCC\_APB2ENR)

Address offset: 0x44

RCC  $\rightarrow$  APB1ENR  $\mid = 0 \times 1;$ 

Reset value: 0x0000 0000

Access: no wait state, word, half-word and byte access.

| 31   | 30           | 29         | 28         | 27           | 26         | 25         | 24         | 23     | 22     | 21           | 20           | 19   | 18          | 17          | 16         |
|------|--------------|------------|------------|--------------|------------|------------|------------|--------|--------|--------------|--------------|------|-------------|-------------|------------|
| Res. | Res.         | Res.       | Res.       | Res.         | LTDC<br>EN | Res.       | Res.       | SAI2EN | SAI1EN | SPI6EN       | SPI5EN       | Res. | TIM11<br>EN | TIM10<br>EN | TIM9<br>EN |
|      |              |            |            |              | rw         |            |            | rw     | rw     | rw           | rw           |      | rw          | rw          | rw         |
| 15   | 14           | 13         | 12         | 11           | 10         | 9          | 8          | 7      | 6      | 5            | 4            | 3    | 2           | 1           | 0          |
| Res. | SYSCFG<br>EN | SPI4<br>EN | SPI1<br>EN | SDMMC1<br>EN | ADC3<br>EN | ADC2<br>EN | ADC1<br>EN | Res.   | Res.   | USART6<br>EN | USART1<br>EN | Res. | Res.        | TIM8<br>EN  | TIM1<br>EN |
|      | rw           | ΓW         | rw         | rw           | rw         | rw         | rw         |        |        | rw           | ΓW           |      |             | rw          | rw         |

Bit 0 TIM1EN: TIM1 clock enable

This bit is set and cleared by software.

0: TIM1 clock disabled

1: TIM1 clock enabled





## $GPIOA->MODER \mid = 0x0800;$

# GPIOA->AFR[0] = 0x01000000; //PAS

# 6.4.9 GPIO alternate function low register (GPIOx\_AFRL) (x = A..K)

Address offset: 0x20

Reset value: 0x0000 0000

| 31                  | 30 | 29 | 28 | 27 | 26                | 25 | 24 |   | 23        | 22     | 21 | 20        | 19 | 18 | 17 | 16 |
|---------------------|----|----|----|----|-------------------|----|----|---|-----------|--------|----|-----------|----|----|----|----|
| AFR7[3:0] AFR6[3:0] |    |    |    |    | AFR5[3:0] AFR4[3: |    |    |   |           | 4[3:0] |    |           |    |    |    |    |
| rw                  | rw | rw | rw | rw | rw                | rw | rw |   | rw        | rw     | rw | rw        | rw | rw | rw | rw |
| 15                  | 14 | 13 | 12 | 11 | 10                | 9  | 8  | _ | 7         | 6      | 5  | 4         | 3  | 2  | 1  | 0  |
| AFR3[3:0]           |    |    |    |    | AFR2[3:0]         |    |    |   | AFR1[3:0] |        |    | AFR0[3:0] |    |    |    |    |
| rw                  | rw | rw | rw | rw | rw                | rw | rw |   | rw        | rw     | rw | rw        | rw | rw | rw | rw |

Bits 31:0 **AFRy[3:0]:** Alternate function selection for port x pin y (y = 0..7) These bits are written by software to configure alternate function I/Os

AFSELy selection:

| 0000: AF0 | 1000: AF8  |
|-----------|------------|
| 0001: AF1 | 1001: AF9  |
| 0010: AF2 | 1010: AF10 |
| 0011: AF3 | 1011: AF11 |
| 0100: AF4 | 1100: AF12 |
| 0101: AF5 | 1101: AF13 |
| 0110: AF6 | 1110: AF14 |
| 0111: AF7 | 1111: AF15 |
|           |            |

| BIN        | 0001 | 0000 | 0000 |
|------------|------|------|------|
| <b>0</b> X | 1    | 0    | 0    |





|   |     | AF0 | AF1                       | AF2          | AF3                             | A          |  |
|---|-----|-----|---------------------------|--------------|---------------------------------|------------|--|
| P | ort | sys | TIM1/2                    | TIM3/4/5     | TIM8/9/10/<br>11/LPTIM<br>1/CEC | 12C<br>4/( |  |
|   | PA0 | -   | TIM2_C<br>H1/TIM2<br>_ETR | TIM5_C<br>H1 | TIM8_ET<br>R                    |            |  |
|   | PA1 | -   | TIM2_C<br>H2              | TIM5_C<br>H2 | -                               |            |  |
|   | PA2 | -   | TIM2_C<br>H3              | TIM5_C<br>H3 | TIM9_CH<br>1                    |            |  |
|   | PA3 | -   | TIM2_C<br>H4              | TIM5_C<br>H4 | TIM9_CH<br>2                    |            |  |
|   | PA4 | -   | -                         | -            | -                               |            |  |

### 23.4.6 TIMx event generation register (TIMx\_EGR)

Address offset: 0x14 Reset value: 0x0000

| Res.         Res.         Res.         Res.         Res.         Res.         Res.         TG         Res.         CC4G         CC3G         CC2G         CC1G         UG           W         W         W         W         W         W         W         W         W | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6  | 5    | 4    | 3    | 2    | 1    | 0  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|------|------|----|------|------|------|------|------|----|
|                                                                                                                                                                                                                                                                       | Res. | TG | Res. | CC4G | CC3G | CC2G | CC1G | UG |
|                                                                                                                                                                                                                                                                       |      |      |      |      |      |      |      |      |      | w  |      | w    | w    | w    | w    | w  |

Bits 15:7 Reserved, must be kept at reset value.

Bit 6 TG: Trigger generation

This bit is set by software in order to generate an event, it is automatically cleared by hardware.

0: No action

1: The TIF flag is set in TIMx\_SR register. Related interrupt or DMA transfer can occur if

Bit 5 Reserved, must be kept at reset value.

Bit 4 CC4G: Capture/compare 4 generation

Refer to CC1G description

Bit 3 CC3G: Capture/compare 3 generation

Refer to CC1G description

Bit 2 CC2G: Capture/compare 2 generation

Refer to CC1G description

Bit 1 CC1G: Capture/compare 1 generation

This bit is set by software in order to generate an event, it is automatically cleared by hardware.

0: No action

1: A capture/compare event is generated on channel 1:

#### If channel CC1 is configured as output:

CC1IF flag is set, Corresponding interrupt or DMA request is sent if enabled.

#### If channel CC1 is configured as input:

The current value of the counter is captured in TIMx\_CCR1 register. The CC1IF flag is set, the corresponding interrupt or DMA request is sent if enabled. The CC1OF flag is set if the CC1IF flag was already high.

#### Bit 0 **UG**: Update generation

This bit can be set by software, it is automatically cleared by hardware.

0: No action

1: Re-initialize the counter and generates an update of the registers. Note that the prescaler counter is cleared too (anyway the prescaler ratio is not affected). The counter is cleared if the center-aligned mode is selected or if DIR=0 (upcounting), else it takes the auto-reload value (TIMx\_ARR) if DIR=1 (downcounting).









# INGENIERÍA MECATRÓNIC UMNG

# **EJERCICIO EN CLASE:**

- 1. Modificar el programa para que opere por el canal 2.
- 2. Medir la duración de un pulso de entrada y visualizar por LCD alfanumérica o enviar el dato por serial al computador .
- 3. Hacerlo por interrupción del timer.

